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DETAILED ACTION 

1 . This Office action is in response to the amendment filed on January 30, 2009, entered by 
the RCE filed on the same date. 

2. Claims 1-7, 9, 12, 13, 16, and 18 are pending. 

3. Claims 1, 3, 4, 9, 13, 16, and 18 have been amended. 

4. Claims 8, 10, 11, 14, 15, 17, and 19-31 have been canceled. 

5. Claims 1-7, 9, 12, 13, 16, and 18 are allowed, renumbered as 1-12. 

6. The objections to Claims 1-14, 16, 18, and 19 are withdrawn in view of Applicant's 
amendments to the claims or cancellation of the claims. 

Examiner's Amendment 

7. An Examiner's amendment to the record appears below. Should the changes and/or 
additions be unacceptable to Applicant, an amendment may be filed as provided by 37 CFR 
1.312. To ensure consideration of such an amendment, it MUST be submitted no later than the 
payment of the issue fee. 

Authorization for this Examiner's amendment was given in a telephone interview with 
Clay D. Hagler (Reg. No. 61,804) on April 9, 2009. 

The application has been amended as follows: 



AMENDMENTS TO THE CLAIMS 
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The amendment document filed on January 30, 2009 is considered non-compliant 
because it has failed to meet the requirements of 37 CFR 1.121 — namely, the status identifier for 
Claim 1 is incorrect. In order for the amendment document to be compliant, please amend the 
status identifier as follows: 

On page 4 of the amendment document, please replace the status identifier for Claim 1 , 
"Proposed Amended," with the status identifier "Currently Amended." 

Please cancel Claims 14, 15, 17, and 19-31 and amend Claims 1, 13, 16, and 18 as 
follows: 

1 . (Currently Amended) A method for generating an installation file for a particular 
version of a relational database, the method comprising: 

given a database system of a particular version, the particular version being unknown 
prior to execution of the method, determining the particular version of the relational database 
wherein metadata exists that describes a sequence of multiple versions of the relational database 
where each version is an upgrade from a previous version, and the particular version is not a first 
version in the sequence; 

automatically determining a first set of scripts, the first set of scripts comprising data 
definition language (DDL) scripts associated with implementing the particular version of the 
relational database, wherein the first set of scripts are selected from a plurality of scripts, one or 
more of the plurality of scripts being not associated with implementing the particular version; 

the automatically determining a first set of scripts comprising: 
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extracting a set A 1 comprising one or more filenames from metadata associated 
with a first version in the sequence, the one or more filenames associated with a file 
comprising a data definition language (DDL) script associated with the first version; 

iteratively extracting a set A i comprising zero or more filenames from metadata 
associated with an /'* version of the relational database, the zero or more filenames each 
associated with a file comprising a data definition language script to be executed when 
upgrading from version i - 1 of the relational database to version i of the relational 
database, where i varies incrementally from 2 to j , where the particular version is j ; 
and 

determining the first set of scripts as a set theory union of sets A l ,A 2 ,...,A J ; 
automatically determining a second set of scripts, the second set of scripts comprising 
data manipulation language (DML) scripts associated with implementing the particular version 
of the relational database, wherein the second set of scripts are selected from a plurality of 
scripts, one or more of the plurality of scripts being not associated with implementing the 
particular version[[,]]; 

the automatically determining a second set of scripts comprising: 

extracting a set A x comprising one or more filenames from metadata associated 
with a first version in the sequence, the one or more filenames associated with a file 
comprising a data manipulation language (DML) script associated with the first version; 

iteratively extracting a set A i comprising zero or more filenames from metadata 
associated with an i th version of the relational database, the zero or more filenames each 
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associated with a file comprising a data manipulation language [[DML]] script to be 
executed to add or modify a DML object when upgrading from version i - 1 of the 
relational database to version / of the relational database, where i varies incrementally 
from 2 to j , where the particular version is j ; 

iteratively extracting a set B i comprising zero or more filenames from metadata 

associated with an i lh version of the relational database, the zero or more filenames each 
associated with a file comprising a DML drop script to be executed to drop a DML object 
when upgrading from version i - 1 of the relational database to version i of the relational 
database, where / varies incrementally from 2 to j , where the particular version is j ; 
and 

determining the second set of scripts C ; by determining: 



; and 

generating an installation file comprising a set theory union of the first set of scripts and 
the second set of scripts. 



C 2 

c 3 



[4lkl-*2. 

[C 2 \jA 3 ]-B 3 , 
[C 3 \JA 4 ]-B 4 , 



K"; U-';l " ■ 



Application/Control Number: 10/796,613 Page 6 

Art Unit: 2191 

13. (Currently Amended) A method for generating an upgrade file to upgrade version i 
of a relational database to version j of the relational database, where j >i, the method 
comprising: 

determining a set A of data definition language (DDL) scripts that, when executed, 
perform creates, alters, and drops of DDL objects associated with version i of the relational 
database, resulting in DDL objects associated with version j of the relational database , wherein 
the determining a set A comprises: 

iteratively extracting sets M k , each comprising zero or more filenames from 
metadata associated with a k' h version of the relational database, where i < k <= j , the 
zero or more filenames each associated with a file comprising a data definition language 
script to be executed when upgrading from version k - 1 of the relational database to 
version k of the relational database; and 

determining the set A _ as the set theory union of sets M, , , , M, , 2 M } 

(A = M M \jM i+2 \J..{jM j ) ; 

determining a set B of data manipulation language (DML) scripts that, when executed, 
create DML objects that are associated with version j of the relational database, but that are not 
associated with version i of the relational database , wherein the determining a set B comprises: 
determining a set E _ of DML scripts that when executed: 
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perform alters of DML objects associated with version i and version / of 
the relational database, but that differ between version i and version / of the 
relational database; and 

perform creates of DML objects that are associated with version / of the 
relational database but that are not associated with version i of the relational 
database; and 

determining set _g_ as the difference between sets E _ and C (B = E-C); 
determining a set C of DML scripts that, when executed, modify DML objects that are 
associated with both version i and version j of the relational database, but that differ between 
version i and version j of the relational database , wherein the determining a set C comprises: 
determining a set E of DML scripts that when executed: 

perform alters of DML objects associated with version / and version /' of 
the relational database, but that differ between version / and version / of the 

relational database; and 

perform creates of DML objects that are associated with version / of the 
relational database but that are not associated with version i of the relational 
database; 

determining a set F, of DML scripts that when executed, create DML objects 
associated with version j of the relational database; and 
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determining set C as [[the]] a set theory intersection of set E and set F j 
(C = Ef]F J ) ; 

determining a set D of DML drop scripts that, when executed, drop DML objects that 
are associated with version / of the relational database, but that are not associated with version 
j of the relational database , wherein the determining a set D comprises: 
determining a set E of DML scripts that when executed: 

perform alters of DML objects associated with version / and version / of 
the relational database, but that differ between version i and version / of the 
relational database: and 

perform creates of DML objects that arc associated with version / of the 
relational database but that are not associated with version / of the relational 
database; 

iteratively determining a set F x of DML scripts that when executed, drop DML 
objects associated with version x - 1 of the relational database that are not associated 
with version x of the relational database, where x varies incrementally from i + 1 to / ; 

determining a set G as the set theory union of sets F. , F M , F i+2 ,. . . , Fj 
(G = F i (jF M (J..{jF i+2 )^ md 

determining set D as the difference between set G and set E (D = G — E) ; and 
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generating an upgrade file comprising a set theory union of sets A, B , C , and D 
(A\JB\JC\JD). 

14. (Canceled) 

15. (Canceled) 

16. (Currently Amended) The method as recited in claim [[15]] 13 wherein the 
determining a set E comprises: 

iteratively determining a set P x of DML scripts that when executed will upgrade DML 
objects from version x - 1 of the relational database to version x of the relational database, 
where x varies incrementally from / + 1 to j ; 

iteratively determining a set N x of DML scripts that when executed will drop DML 
objects that are associated with version x - 1 of the relational database but that are not associated 
with version x of the relational database, where x varies incrementally from i + 2 to j; 

iteratively determining a set M x of DML scripts that when executed will upgrade DML 
objects from version i of the relational database to version x of the relational database, where x 
varies incrementally from i + 1 to j , and where: 

M M = P M 

M i+2 =[M M {jP i+2 ]-N i+2 
M i+3 =[M i+2 \JP i+3 ]-N i+3 
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Mj =[M j _ 1 \JP j ]-N j ;and 

determining set E = M r 

17. (Canceled) 

18. (Currently Amended) The method as recited in claim [[17]] 13 wherein the 
determining a set F. comprises: 

extracting a set M l comprising one or more filenames from metadata associated with a 
first version in [[the]] a sequence of multiple versions of the relational database , the one or more 
filenames associated with a file comprising a data manipulation language (DML) script 
associated with the first version; 

iteratively extracting a set M x comprising zero or more filenames from metadata 
associated with version x of the relational database, the zero or more filenames each associated 
with a file comprising a DML script to be executed to add or modify a DML object when 
upgrading from version x - 1 of the relational database to version x of the relational database, 
where x varies incrementally from 2 to j ; 

iteratively extracting a set B x comprising zero or more filenames from metadata 
associated with version x of the relational database, the zero or more filenames each associated 
with a file comprising a DML drop script to be executed to drop a DML object when upgrading 
from version x - 1 of the relational database to version x of the relational database, where x 
varies incrementally from 2 to j ; and 
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determining the set F } by determining: 
F 2 =[M l [jM 2 ]-B 2 , 

F 4 =[F 3 \jM 4 ]-B 4 , 



19-31. (Canceled) 



- END OF AMENDMENT - 



Reasons for Allowance 

8. The following is an Examiner's statement of reasons for allowance: 

The cited prior art taken alone or in combination fail to teach, in combination with the 
other claimed limitations, 

"the automatically determining a first set of scripts comprising: 

extracting a set A l comprising one or more filenames from metadata associated 
with a first version in the sequence, the one or more filenames associated with a file 
comprising a data definition language (DDL) script associated with the first version; 

iteratively extracting a set A t comprising zero or more filenames from metadata 

associated with an i th version of the relational database, the zero or more filenames each 
associated with a file comprising a data definition language script to be executed when 
upgrading from version i - 1 of the relational database to version i of the relational 
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database, where i varies incrementally from 2 to j , where the particular version is j ; 
and 

determining the first set of scripts as a set theory union of sets A l , A 2 Aj ;" and 
"the automatically determining a second set of scripts comprising: 

extracting a set A l comprising one or more filenames from metadata associated 
with a first version in the sequence, the one or more filenames associated with a file 
comprising a data manipulation language (DML) script associated with the first version; 

iteratively extracting a set A i comprising zero or more filenames from metadata 
associated with an i th version of the relational database, the zero or more filenames each 
associated with a file comprising a data manipulation language script to be executed to 
add or modify a DML object when upgrading from version i - 1 of the relational database 
to version i of the relational database, where i varies incrementally from 2 to j , where 
the particular version is j ; 

iteratively extracting a set B t comprising zero or more filenames from metadata 

associated with an i th version of the relational database, the zero or more filenames each 
associated with a file comprising a DML drop script to be executed to drop a DML object 
when upgrading from version / - 1 of the relational database to version i of the relational 
database, where i varies incrementally from 2 to j , where the particular version is j ; 
and 

determining the second set of scripts C } by determining: 
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C 2 =[A l {jA 2 ]-B 2 , 
C 3 =[C 2 [jA 3 ]-B 3 , 
C 4 =[C 3 \jA 4 ]-B 4 , 

('; KVlM/l B r 
" as recited in independent Claim 1 ; and further fail to teach, in combination with the 
other claimed limitations, 

"wherein the determining a set A comprises: 

iteratively extracting sets M \ , each comprising zero or more filenames from 
metadata associated with a k' h version of the relational database, where i < k <= j , the 
zero or more filenames each associated with a file comprising a data definition language 
script to be executed when upgrading from version k - 1 of the relational database to 
version k of the relational database; and 

determining the set A as the set theory union of sets M 1+l , M j+2 M . 

(A = M M \jM i+2 \J..[jM j )r 

"wherein the determining a set B comprises: 

determining a set E of DML scripts that when executed: 

perform alters of DML objects associated with version i and version j of 

the relational database, but that differ between version i and version j of the 

relational database; and 
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perform creates of DML objects that are associated with version j of the 
relational database but that are not associated with version i of the relational 
database; and 

determining set B as the difference between sets E and C (B = E-C) ," 
"wherein the determining a set C comprises: 

determining a set E of DML scripts that when executed: 

perform alters of DML objects associated with version i and version j of 
the relational database, but that differ between version i and version j of the 
relational database; and 

perform creates of DML objects that are associated with version j of the 
relational database but that are not associated with version i of the relational 
database; 

determining a set F } of DML scripts that when executed, create DML objects 
associated with version j of the relational database; and 

determining set C as [[the]] a set theory intersection of set E and set F } 
(C = £f|F.),"and 

"wherein the determining a set D comprises: 

determining a set E of DML scripts that when executed: 

perform alters of DML objects associated with version i and version j of 
the relational database, but that differ between version i and version j of the 
relational database; and 



Application/Control Number: 1 0/796,6 1 3 Page 1 5 

Art Unit: 2191 

perform creates of DML objects that are associated with version j of the 
relational database but that are not associated with version i of the relational 
database; 

iteratively determining a set F x of DML scripts that when executed, drop DML 
objects associated with version x - 1 of the relational database that are not associated 
with version x of the relational database, where x varies incrementally from i + 1 to j ; 

determining a set G as the set theory union of sets F t , F M , F i+2 F } 
(G = ^.U^U-U^);and 

determining set D as the difference between set G and set E (D = G-E)" as 
recited in independent Claim 13. 

The closest cited prior art, the combination of US 6,970,876 (hereinafter "Hotti"), US 
6,415,299 (hereinafter "Baisley"), and "Set Theory," July 2002 (hereinafter "Set_Theory"), 
teaches a method and an arrangement associated with managing database schemas. However, the 
combination of Hotti, Baisley, and SetTheory fails to teach 

"the automatically determining a first set of scripts comprising: 

extracting a set A l comprising one or more filenames from metadata associated 
with a first version in the sequence, the one or more filenames associated with a file 
comprising a data definition language (DDL) script associated with the first version; 

iteratively extracting a set A i comprising zero or more filenames from metadata 

associated with an i th version of the relational database, the zero or more filenames each 
associated with a file comprising a data definition language script to be executed when 
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upgrading from version i - 1 of the relational database to version i of the relational 
database, where i varies incrementally from 2 to j , where the particular version is j ; 
and 

determining the first set of scripts as a set theory union of sets A l , A 2 A } ;" and 
"the automatically determining a second set of scripts comprising: 

extracting a set A l comprising one or more filenames from metadata associated 
with a first version in the sequence, the one or more filenames associated with a file 
comprising a data manipulation language (DML) script associated with the first version; 

iteratively extracting a set A t comprising zero or more filenames from metadata 

associated with an i th version of the relational database, the zero or more filenames each 
associated with a file comprising a data manipulation language script to be executed to 
add or modify a DML object when upgrading from version i - 1 of the relational database 
to version i of the relational database, where i varies incrementally from 2 to j , where 
the particular version is j ; 

iteratively extracting a set B l comprising zero or more filenames from metadata 

associated with an i th version of the relational database, the zero or more filenames each 
associated with a file comprising a DML drop script to be executed to drop a DML object 
when upgrading from version / - 1 of the relational database to version i of the relational 
database, where i varies incrementally from 2 to j , where the particular version is j ; 
and 

determining the second set of scripts C } by determining: 
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C 2 =[A l {jA 2 ]-B 2 , 
C 3 =[C 2 [jA 3 ]-B 3 , 
C 4 =[C 3 \jA 4 ]-B 4 , 

('; KVlM/l B r 
" as recited in independent Claim 1 ; and further fails to teach 
"wherein the determining a set A comprises: 

iteratively extracting sets M k , each comprising zero or more filenames from 
metadata associated with a k th version of the relational database, where i <k <= j , the 
zero or more filenames each associated with a file comprising a data definition language 
script to be executed when upgrading from version k - 1 of the relational database to 
version k of the relational database; and 

determining the set A as the set theory union of sets M M , M i+1 M } 

(A = M M {jM i+2 {J..{jM j )," 

"wherein the determining a set B comprises: 

determining a set E of DML scripts that when executed: 

perform alters of DML objects associated with version i and version j of 
the relational database, but that differ between version i and version j of the 
relational database; and 

perform creates of DML objects that are associated with version j of the 
relational database but that are not associated with version i of the relational 
database; and 
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determining set B as the difference between sets E and C (B = E - C) ," 
"wherein the determining a set C comprises: 

determining a set E of DML scripts that when executed: 

perform alters of DML objects associated with version i and version j of 
the relational database, but that differ between version i and version j of the 
relational database; and 

perform creates of DML objects that are associated with version j of the 
relational database but that are not associated with version i of the relational 
database; 

determining a set F j of DML scripts that when executed, create DML objects 
associated with version j of the relational database; and 

determining set C as [[the]] a set theory intersection of set E and set F } 
(C = £f|F.),"and 

"wherein the determining a set D comprises: 

determining a set E of DML scripts that when executed: 

perform alters of DML objects associated with version i and version j of 
the relational database, but that differ between version i and version j of the 
relational database; and 

perform creates of DML objects that are associated with version j of the 
relational database but that are not associated with version i of the relational 
database; 
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iteratively determining a set F x of DML scripts that when executed, drop DML 
objects associated with version x - 1 of the relational database that are not associated 
with version x of the relational database, where x varies incrementally from i + 1 to j ; 

determining a set G as the set theory union of sets F t , F M , F i+2 ,...,Fj 
(G = F i \jF M \J...\jF i+2 );md 

determining set D as the difference between set G and set E (D = G-E)" as 
recited in independent Claim 13. 

Any comments considered necessary by Applicant must be submitted no later than the 
payment of the issue fee and, to avoid processing delays, should preferably accompany the issue 
fee. Such submissions should be clearly labeled "Comments on Statement of Reasons for 
Allowance." 

Conclusion 

9. Any inquiry concerning this communication or earlier communications from the 
Examiner should be directed to Qing Chen whose telephone number is (571) 270-1071. The 
Examiner can normally be reached on Monday through Thursday from 7:30 AM to 4:00 PM. 
The Examiner can also be reached on alternate Fridays. 

If attempts to reach the Examiner by telephone are unsuccessful, the Examiner's 
supervisor, Wei Zhen, can be reached on 571-272-3708. The fax phone number for the 
organization where this application or proceeding is assigned is 571-273-8300. 
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Any inquiry of a general nature or relating to the status of this application or proceeding 
should be directed to the TC 2100 Group receptionist whose telephone number is 571-272-2100. 

Information regarding the status of an application may be obtained from the Patent 
Application Information Retrieval (PAIR) system. Status information for published applications 
may be obtained from either Private PAIR or Public PAIR. Status information for unpublished 
applications is available through Private PAIR only. For more information about the PAIR 
system, see http://pair-direct.uspto.gov. Should you have questions on access to the Private PAIR 
system, contact the Electronic Business Center (EBC) at 866-217-9197 (toll-free). 



/Q. C.I 

Examiner, Art Unit 2191 
/Wei Y Zhen/ 

Supervisory Patent Examiner, Art Unit 2191 



